<template>
	<div>
		<!-- 面包屑导航 -->
		<el-breadcrumb separator-class="el-icon-arrow-right">
			<el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
			<el-breadcrumb-item>订单管理</el-breadcrumb-item>
			<el-breadcrumb-item>订单列表</el-breadcrumb-item>
		</el-breadcrumb>
		
		<!-- 卡片视图 -->
		<el-card>
			<el-row>
				<el-col>
					  <el-input placeholder="请输入内容">
				
					    <el-button slot="append" icon="el-icon-search"></el-button>
					  </el-input>
				</el-col>
			</el-row>
			
			<!-- 表格订单数据列表 -->
			<el-table :data="orderList" border stripe>
				<el-table-column type="index"></el-table-column>
				<el-table-column label="订单编号" prop="order_number"></el-table-column>
				<el-table-column label="订单价格" prop="order_price"></el-table-column>
				<el-table-column label="是否付款" prop="pay_status">
					<template v-slot="scope">
						<el-tag type="success" v-if="scope.row.pay_status ==='1'">已付款</el-tag>
						<el-tag type="danger" v-else>未付款</el-tag>
					</template>
				</el-table-column>
				<el-table-column label="是否发货" prop="is_send">
					
				</el-table-column>
				<el-table-column label="下单时间" prop="create_time">
					<template v-slot="scope">
						{{scope.row.create_time | dateFormat}}
					</template>
				</el-table-column>
				<el-table-column label="操作">
					<template v-slot="scope">
						<el-button type="primary" icon="el-icon-edit" @click="showBox"></el-button>
						<el-button type="success" icon="el-icon-location" @click="showPro"></el-button>
					</template>
				</el-table-column>
			</el-table>
			
			<!-- 分页 -->
			    <el-pagination
			      @size-change="handleSizeChange"
			      @current-change="handleCurrentChange"
			      :current-page="queryInfo.pagenum"
			      :page-sizes="[5, 10, 15, 20]"
			      :page-size="queryInfo.pagesize"
			      layout="total, sizes, prev, pager, next, jumper"
			      :total="total"
					  background>
			    </el-pagination>
		</el-card>
		<!-- 省市区域对话框 -->
		<el-dialog
		  title="修改地址"
		  :visible.sync="addVisible"
		  width="50%" @close="addressClose">
			<!-- 表单 -->
		  <el-form :model="addruleForm" :rules="addrulesRules" ref="addruleFormRef" label-width="100px">
		    <el-form-item label="省市区/县" prop="address1">
		      <el-cascader :options="cityData" v-model="addruleForm.address1"></el-cascader>
		    </el-form-item>
				<el-form-item label="详细地址/县" prop="address2">
				  <el-input v-model="addruleForm.address2"></el-input>
				</el-form-item>
			</el-form>
		  <span slot="footer" class="dialog-footer">
		    <el-button @click="dialogVisible = false">取 消</el-button>
		    <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
		  </span>
		</el-dialog>
		
		<!-- 修改物流 -->
		<el-dialog
		  title="物流进度"
		  :visible.sync="proressVisible"
		  width="50%">
		  
			 <el-timeline>
			    <el-timeline-item
					  :reverse="reverse"
			      v-for="(activity, index) in proressInfo"
			      :key="index"
			      :timestamp="activity.time">
			      {{activity.context}}
			    </el-timeline-item>
			  </el-timeline>
		</el-dialog>
		
	</div>
</template>

<script>
	import cityData from './citydata.js'
	export default {
		data() {
			return {
				reverse: true,
				queryInfo: {
					query: '',
					pagenum: 1,
					pagesize: 10
				},
				
				orderList: [],
				total: 0,
				// 省市区对话框显示与隐藏
				addVisible: false ,
				//修改地址对话框显示与隐藏
				proressVisible: false,
				// 省市区数据双向绑定
				addruleForm: {
					address1: [],
					address2: ''
				},
				//保存的物流信息
				proressInfo: [],
				
				addrulesRules: {
					address1: [
						{ required: true, message: '请选择省市区县', trigger: 'blur'}
					],
					address2: [
						{ required: true, message: '请填写详细地址', trigger: 'blur'}
					]
				},
				cityData :cityData
			}
		},
		created() {
			this.getOrderList()
		},
		methods:{
			async getOrderList() {
				const { data : res } = await this.$http.get('/orders',{params: this.queryInfo})
				if(res.meta.status !== 200) {
					return this.$message.error('获取订单列表失败')
				}
				console.log(res)
				this.total = res.data.total
				this.orderList = res.data.goods
			},
			handleSizeChange(newsize) {
				this.queryInfo.pagesize = newsize
				this.getOrderList()
			},
			handleCurrentChange(newpage) {
				this.queryInfo.pagenum = newpage
				this.getOrderList()
			},
			// 展示修改地址对话框
			showBox() {
				this.addVisible = true
			},
			// 清空级联选择器
			addressClose() {
				this.$refs.addruleFormRef.resetFields()
			},
			 async showPro() {
				const {data:res} = await this.$http.get('/kuaidi/1106975712662')
				if(res.meta.status !== 200) {
					return this.$message.error('获取物流进度失败')
				}
				this.proressInfo = res.data
				
				this.proressVisible = true	
				
				console.log(this.proressInfo)
			}
		}
	}
</script>

<style lang="less" scoped>
	.el-cascader {
		width: 100%;
	}
</style>
